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DESCRIPTION 

DATA PROCESSING APPARATUS AND DATA PROCESSING METHOD, 

AND COMPUTER PROGRAM 

5 TECHNICAL FIELD 

The present Invention relates to a data 
processing apparatus and data processing method and, 
more particularly , to a management method of page data 
in a multi-function peripheral apparatus (to be 
10 referred to as an MFP apparatus hereinafter) that 
handles page data in a plurality of data formats, 

BACKGROUND ART 

In a conventional MFP apparatus which handles 

15 image data in a plurality of data formats, an image 
data input unit such as scanning, FAX reception, 
network reception, and the like encodes /decodes page 
data input from an input interface to that in a data 
format (encoding format) unique to the apparatus, and 

20 stores the page data in the apparatus as storage data. 
Also, an image data output unit such as 
recording, FAX transmission, network transmission, and 
the like converts the storage data stored in the data 
format unique to the apparatus into a required data 

25 format, and outputs the converted data to an output 

interface. As described above, page data in different 
data formats (encoding formats), which are generated by 
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the input and output units and are used, are 
independently managed. 

Fig. 1 shows the structure of page management 
records in such conventional MFP apparatus. That is, 
an image (Raw data) scanned by an image reader 
(scanner) is encoded to JBIG as an encoding format 
unique to the MFP apparatus, and is stored in a memory 
as JBIG data. Upon using this JBIG data, it is 
converted into a data format (encoding format) required 
for a function to be used (e.g., a FAX transmission 
function), and the converted data is used. Therefore, 
the conventional MFP apparatus manages data to be 
handled in a single encoding format like, e.g., JBIG. 
As shown in Fig. 1, page management records 10a, 
10b,... respectively manage only JBIG page data 20a, 
20b,.... Note that JBIG data is stored in a memory 
managed by the JBIG page data. 

However, the conventional MFP apparatus manages 
and stores data in a common data format (JBIG format). 
When raw data is input and is immediately output 
(copied) , raw data — + JBIG conversion is purposely 
made, and a storage process is then executed. After 
that, since JBIG data raw data re-conversion is 
made, a time loss for the storage process is produced, 
resulting in a low output speed. 

In the conventional MFP apparatus, for example, 
when the first page is JBIG data, the second page is 
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TXT data, and the third page is TIFF data in a single 
document, each page management record can only have 
page data in a specific data format unique to the 
apparatus, and cannot manage each page in an original 
encoding format. Hence, the image data output unit 
cannot use page data until the image data input unit 
completes encoding /decoding to storage data and 
generates page data, thus requiring a long processing 
time from input to output of image data* 

If the conventional MFP apparatus supports and 
manages data in various different data formats 
(encoding formats), it must generate page data in 
different data formats (encoding formats) and must 
manage them independently although they form a single 
document, as shown in Figs. 2A to 2C. That is, when 
the image data output unit (recording, FAX 
transmission, network transmission) that requires data 
format conversion must have page management records for 
page data conversion and page data themselves, and 
management is made in this way, the memory use size 
Increases, resulting in high apparatus cost. 

The present invention has been made to solve the 
aforementioned problems, and has as its object to 
provide a data process apparatus which can Implement an 
encoding process which efficiently supports respective 
image processing functions while minimizing the memory 
use size in the apparatus. 
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DISCLOSURE OF INVENTION 
According to one aspect of the present Invention, 
preferably, a data processing apparatus for processing 
data for respective pages, comprises a data reception 
unit for receiving at least data of a first format for 
respective pages, a data conversion unit for converting 
the data of the first format into data of a second 
format, a page data management unit for managing the 
data of the first and second formats in first and 
second page data in association with each other and a 
control unit for monitoring a storage state of the data 
of the first format in a memory, and permitting a 
predetermined process for the data of the first format 
in accordance with the storage state. 

According to another aspect of the present 
invention, preferably, a data processing method for 
processing data for respective pages, comprises a data 
reception step of receiving at least data of a first 
format for respective pages, a first page data 
generation step of generating first page data used to 
manage the data of the first format, a control step of 
monitoring a storage state of the data of the first 
format in the memory, and permitting a predetermined 
process for the data of the first format in accordance 
with the storage state, a data conversion step of 
converting the data of the first format into data of a 
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second format, a second page data generation step of 
generating second page data used to manage the data of 
the second format and a page data management step of 
managing the data of the first and second formats in 
first and second page data in association with each 
other. 

Other features and advantages of the present 
invention will be apparent from the following 
description taken in conjunction with the accompanying 
drawings, in which like reference characters designate 
the same or similar parts throughout the figures 
thereof . 

BRIEF DESCRIPTION OF DRAWINGS 
The accompanying drawings, which are incorporated 
in and constitute a part of the specification, 
illustrate embodiments of the invention and, together 
with the description, serve to explain the principles 
of the invention. 

Fig. 1 shows the structure of page management 
records in the conventional MFP apparatus; 

Figs. 2A to 2C are schematic views showing the 
page data management method when the conventional MFP 
apparatus supports and manages data in various 
different data formats (encoding formats); 
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Fig, 3 Is a block diagram showing the arrangement 
of an Image processing apparatus 100 according to the 
present invention; 

Fig. 4 shows the structure of page management 
records according to the present invention; 

Fig. 5 is a schematic view showing the page data 
management method using the page management records 
according to the present invention; 

Fig. 6 is a view showing a detailed example of 
the page data management method using the page 
management records according to the present invention; 

Fig. 7 is a schematic diagram showing the 
relationship among the page management record, page 
data, and respective processors according to the 
present invention; 

Fig. 8 is a flowchart for explaining the page 
data generation and management operations using the 
page management records according to the present 
invention; 

Fig. 9 is a schematic view for explaining an 
example of a series of operations from data scanning 
until generation of page management records; 

Fig. 10 is a flowchart for explaining an example 
of the page data control operation using the page 
management records according to the present invention; 

Fig. 11 is a view showing the concept of the page 
data control operation; 
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Fig, 12 ±s a view showing the concept of another 
page data control operation; and 

Fig. 13 is a view showing the concept of still 
another page data control operation. 

BEST MODE FOR CARRYING OUT THE INVENTION 
An MFP (multi-function peripheral) apparatus will 
be exemplified hereinafter in association with a data 
processing apparatus according to the present 
invention. 

< Hardware Arrangement > 

Fig. 3 is a block diagram showing the arrangement 
of an image processing apparatus as an embodiment of 
the present invention. 

Referring to Fig. 3, an image processing 
apparatus 100 has a CPU 101, ROM 102, RAM 103, scanner 
104, printer 105, CODEC 106, operation/display unit 
107, line I/F 108, network I/F 110, and USB I/F 112. 

The CPU 101 serves as a system controller, and 
controls the overall image processing apparatus 100. 
The ROM 102 stores a control program of the CPU 101. 
Note that the aforementioned control program is used to 
implement the embodiment to be described hereinafter. 
The ROM 102 also stores a memory management program of 
a memory manager 610 (to be described later; Fig. 9). 

The RAM 103 comprises an SRAM, DRAM, or the like, 
and stores program control variables and the like. The 
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RAM 103 also stores setting values registered by the 
user of the Image processing apparatus 100 , management 
data of the Image processing apparatus 100 , and the 
like, and various work buffers. 

In this embodiment, a page management record 200 
and page data 210 are stored in the RAM 103 every time 
they are generated, and are deleted from the RAM 103 
when a release process Is executed. 

The scanner 104 comprises a CS image sensor, 
document feeder mechanism, and the like. The scanner 
104 optically scans a document image, and converts it 
into electrical image data. 

The printer 105 prints a received image or file 
data on a print sheet. 

The CODEC 106 is a module for performing encoding 
and decoding such as JBIG, JPEG, and the like, i.e., a 
processor for executing compression and expansion 
processes of image data complying with a predetermined 
standard. 

The operation/display unit 107 comprises a 
keyboard, touch panel, LCD, LED, and the like. The 
operation/display unit 107 is used by the apparatus 
user to make various operations, and displays messages 
to the apparatus user. 

The line I/F 108 comprises a modem 
(modulator /demodulator) , NCU (network control unit). 
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and the like, and performs FAX transmission /reception 
via a telephone line 109. 

The network I/F 110 and USB I/F 112 perform 
interface control with a connected external PC via a 
network 111 and USB 113. Job requests such as a print 
job, scan job, and the like can be received from the PC 
via these Interfaces. 
<Page Data Management Method> 

Figs. 4 to 7 are schematic views showing the page 
data management method according to the present 
invention. Note that page management records 200a, 
200b, 200c,... are not already prepared in the RAM 103 
but are generated if they are required, and are deleted 
when they become unnecessary. This operation will be 
described later. 

Fig. 4 is a schematic view showing the mutual 
relationship among the page management records 200a, 

200b, 200c, , and also the relationship between one 

page management record (e.g.., 200a) and encoding modes 
to be managed in that record. 

Referring to Fig. 4, a page management record is 
management data used to manage page data corresponding 
to respective encoding modes, and stores various kinds 
of information associated with page data (the detailed 
structure will be described later) . When an image 
includes a plurality of pages, the page management 
record saves a pointer to a page management record of 
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the next page, and page management records are 
associated with each other using a tree structure. 

In this embodiment , the page management record 
can have a plurality of page data of different encoding 
formats (data formats) such as Raw Mono, Raw Color, 
JBIG, JPEG, TIFF, TEXT, and the like, as needed. 

More specifically, each page management record 
saves pointers to respective page data, as shown in 
Fig. 5. For example, the page management record 200a 
for the first page manages RAW page data 220 and JBIG 
page data 230 of those of supported encoding formats. 
Each page data stores RAW data and JBIG data at 
predetermined address positions of a memory block which 
is managed in association with that page data. 

Likewise, the page management record 200b for the 
second page manages TXT page data 240 associated with 
text data, and the page management record 200c for the 
third page manages TIFF page data associated with TIFF 
data, and JPEG page data associated with JPEG data. 
Note that these combinations are merely examples, and 
other combinations are available, as a matter of 
course. 

Fig. 6 shows the structure of the page management 
record 200, and the relationship among the page 
management record 200, JBIG page data 210c, RAW page 
data 210a, and Memory_Block 310. A combination of 
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these data formats (encoding formats) Is merely an 
example, and another combination is available. 

As shown in Pig. 6, the page management record 
includes a Next pointer, Prev pointer, Page_No., Code, 
Status, Link_Count, Free_Flag, and the like. Note that 
the Next pointer Indicates a pointer (address on the 
RAM 103) of the page management record of the next 
page, and stores "Null" when no next page is available. 
The Prev pointer indicates a pointer of the page 
management record of the previous page, and stores 
"Null" when no previous page is available (when the 
page of interest is the first page). 

Page_No. is information indicating the page 
position of a document to be processed of the page of 
interest. Code is information indicating the encoding 
formats of data to be managed. In the example of 
Fig. 6, RAW (raw) data and JBIG data core to be managed. 

Status manages two types of information, i.e., 
the status of the overall page management record 200 
and the status of each encoding format. The status 
Includes RUN indicating generation in progress, and FIX 
indicating completion of generation. For example, when 
this Status indicates generation in progress of the 
JBIG page data 210c (RUN) , other processors such as a 
print processor, FAX processor, and the like cannot use 
that JBIG data, and must stand by until Status 
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indicates completion of generation of the JBIG data 
(FIX) . 

Link_Count indicates processors that refer to the 
page management record 200 of interest. That is, when 
an arbitrary processor (which can be the print 
processor or FAX processor) refers to the page 
management record 200 of interest and is about to use 
predetermined data managed by that record, this 
Link_Count counts the number of processors that refer 
to this record. When none of processors refer to this 
record, Link_Count is "0". 

Free_Flag is set "ON" when reference to the page 
management record 200 of interest by the processor is 
complete, and that page management record can be 
deleted. Therefore, when the Llnk_Count is "0" and 
Free_Flag is "ON", it is determined that reference by 
all the processors is complete, and that page 
management record 200 can be deleted. 

For the purpose of easy understanding, an 
operation example associated with Status, Link_Count, 
and Free_Flag will be described below using Fig, 7. 
When a document is scanned by a scanner processor 410, 
a page management record generation request is issued. 
In this state. Status Indicates that the page 
management record = "RUN" . As data are scanned by the 
scanner processor 410, RAW page data are generated, and 
are stored in an associated memory. Furthermore, JBIG 
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page data are generated, and the RAW data are encoded 
by JBIG and are stored in the memory. Before these 
page data are generated and are stored, RAW page data - 
"RUN" or JBIG data - "RUN" in Status. After these data 
5 are stored, RAW page data - "FIX" or JBIG data = "FIX" 
in Status. 

In this case, when a printer processor 420 and 
FAX processor 430 refer to the page management record 
200 of interest to use RAW data or JBIG data, 

10 Link_Count indicates "2". When both the printer 
processor 420 and FAX processor 430 have ended 
reference, Link_Count becomes "0". On the other hand, 
when the printer processor 420 or FAX processor 430 has 
ended reference, it issues a delete request (release 

15 request) to the page management record 200, and 
Free_Flag is set "ON" in this case. As described 
above, when Link_Count = "0" and Free_Flag = "ON" , the 
role of the page management record 200 of interest is 
fulfilled, and that record is deleted. 

20 Referring back to Fig. 6, the relationship 

between the page data and memory block 310 will be 
explained. As described above, each page management 
record 200 manages generation and its completion, 
deletion, and the like of page data 210 for each 

25 encoding format. Fig. 6 exemplifies a case wherein RAW 
data and JBIG data are generated. 
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Each page data has Width; Length, Size, 
MemoryJBlock, and the like as its structure. Note that 
Width indicates the number of main scan dots of the 
scanned image, and Length indicates the number of 
sub-scan dots of that image. Based on these two 
parameters, the size of the image (X dots x Y dots) can 
be determined. 

Size indicates the data size of the image data. 
Memory_Block indicates the address of the first memory 
block 310 where actual data is stored. 

In Fig. 6, raw data obtained by scanning image 
data by the scanner processor 410 is managed by 
generated RAW page data, and is stored in the memory 
block 310. Each memory block 310 is formed by, e.g., 
segmenting the RAM 103 into a plurality of memory 
areas. Data that cannot be stored in one memory block 
310 is also stored in another memory block 310, and 
these memory blocks are associated by pointers. A Next 
pointer Indicates the next memory block where data is 
stored, and a Prev pointer indicates the immediately 
preceding block where data is stored. In this manner, 
by segmenting the data storage areas, the memory can be 
efficiently used. Note that Fig. 6 exemplifies a case 
wherein actual data is stored in the area of the memory 
block 310. Alternatively, data may be managed by still 
another memory area, and the memory block 310 may 
manage only its address pointer. 
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<Page Data Control Operation> 

Figs. 8 to 13 are flowcharts and the like showing 
the page data control operation when a monochrome copy- 
process Is executed as an example of the Image process. 
Note that the operations of these flowcharts are 
controlled by the CPU 101. 

The page data control method of an Image scanner 
unit upon executing the monochrome copy process will be 
described below using Fig. 8. 

If it is determined in step S501 that a scan 
start request is issued by the scanner 104 (= 410 in 
Fig. 7), the flow advances to step S502. 

In step S502, a page management record 200 is 
acquired. Fig. 9 shows an overview of this acquisition 
operation. When the scanner processor 410 begins to 
scan images, and prepares for scanning the image of the 
first page (620), a request that instructs to generate 
a page management record is Issued to the memory 
manager 610. The memory manager 610 is implemented by 
a software program stored in the ROM 102, and manages 
the number of current page management records , page 
management records in use, and the like. Upon 
reception of the request, the memory manager 610 
creates a page management record 200 on a page 
management record area of a memory map 630. A page 
management record area 640 is managed for respective 
page management records (#1, #2, #3, ), and if use of 
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a given page management record ends, that record is 
released (deleted) from the page management record area 
640, and its free area is used for another page 
management record. In this way, the page management 
record for the image of the first page is acquired. 

Referring back to the flowchart of Fig. 8, Raw 
page data is acquired in step S503. After the page 
management record is acquired, a Raw page data 
generation request is Issued from the scanner processor 
410 to the memory manager 610, and Raw page data 
corresponding to the image data of the first page is 
generated on a page data area of the memory map 630 in 
the same manner as in generation of the page management 
record . 

Image data (first page) scanned in step S504 is 
stored as raw data in a memory block associated with 
the Raw page data in step S505. At this time, the page 
management record and Raw page data are acquired, as 
indicated by 810 and 820 in Fig. 11. 

Upon completion of the scan process for one page, 
a page FIX message is output in step S506. At this 
time, in Status (Fig. 6) described above, status has 
changed from "RUN" to n FIX n for Raw data. With this 
status, other processors (printer processor, FAX 
processor, and the like) can use this Raw data. 

In step S507, JBIG page data is acquired. An 
overview of this process is Indicated by 830 in 
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Fig. 11. In step S508, the Raw page data stored In 
step S505 is encoded by JBIG. In step S509, JBIG data 
obtained by encoding the Raw data by JBIG is stored in 
the JBIG page data acquired in step S507 (840, 
Fig. 11). At this time, if the Raw page data whose 
JBIG encoding is complete is not referred to by other 
processors, that Raw page data can be released (850). 

If it is determined in step S510 that the next 
page is present, the flow returns to step S502, and the 
processes for the next and subsequent pages similarly 
continue. If it is determined in step S510 that no 
next page is present, the flow returns to step S501 to 
wait for another scan start request. In this way, if a 
plurality of pages of images are scanned, the memory 
manager 610 generates page management records in 
correspondence with the number of pages, and are 
associated with each other, as shown in Fig. 4. 

Fig. 10 is a flowchart for explaining the page 
data control operation of the printer (= 420 in 
Fig. 7) 105 when the monochrome copy process is done as 
an example. 

If it is determined in step S701 that a print 
process instruction is Issued and a printable page is 
available, the flow advances to step S702. 

It is checked in step S702 if "FIX" JBIG page 
data is available. That is, in case of a normal print 
operation, since the print operation is executed by 
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decoding JBIG data ±nto Raw data, it is checked first 
if JBIG data is available. 

If it is determined in step S702 that no "FIX 1 " 
JBIG page data is available. Raw data managed by Raw 
page data is printed out in step S703, and the flow 
returns to step S701. This phenomenon occurs when the 
print process of the first page is done. Even when the 
image of the first page is not encoded by JBIG, since 
the print process can be executed using Raw data, 
impression that the high-speed print process is 
executed can be given to the user. Note that the Raw 
page data which has been printed out to the printer can 
be released when it is not referred to by other 
processors. Fig. 12 shows this state. That is. Raw 
data managed by Raw page data undergoes a print 
process, and is sequentially encoded by JBIG. At this 
time, if JBIG data are stored in memory blocks managed 
by JBIG data and are not referred to other processors 
(e.g., the FAX processor and the like). Raw page data 
is released (deleted from the corresponding page 
management record), as indicated by 920. 

If it is determined in step S702 that "FIX" JBIG 
page data is available. Raw page data 1010 is acquired, 
as shown in Fig. 13, in step S704. Since this 
acquisition operation has already been explained, a 
description thereof will be omitted. 
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In step S705, JBIG data managed by the JBIG page 
data is decoded to generate Raw data. 

Next, in step S706 the decoded Raw data is stored 
in a memory block associated with the Raw page data 
acquired in step S704. 

In step S703, the Raw data stored in the Raw page 
data is printed out . If the Raw page data 
corresponding to the Raw data which has been printed 
out to the printer is not referred to by other 
processors, that Raw page data can be released (deleted 
from the corresponding page management record) . 

The aforementioned operation is repeated until 
the printout processes for all pages are completed. 
<Effect Of Embodiment > 

As described above, according to this embodiment, 
since one page management record has a plurality of 
page data which are stored in different encoding 
formats, the output side that requires conversion of an 
encoding format need not independently have page 
management records for rendering and page data, the 
memory diversity can be accommodated, and the memory 
use size can be reduced. If already "FIX" page data is 
available, since the processor that uses page data can 
use that page data even when encoding/decoding is in 
progress, high-speed processing can be attained. 

That is, according to this embodiment, encoding 
processes corresponding to respective image processing 
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functions can be efficiently implemented while 
minimizing the memory use size in the apparatus. 
<Other Embodiments > 

Note that the present invention can be applied to 
an apparatus comprising a single device or to system 
constituted by a plurality of devices. 

Furthermore, the invention can be implemented by 
supplying a software program , which implements the 
functions of the foregoing embodiments, directly or 
indirectly to a system or apparatus, reading the 
supplied program code with a computer of the system or 
apparatus, and then executing the program code. In 
this case, so long as the system or apparatus has the 
functions of the program, the mode of implementation 
need not rely upon a program. 

Accordingly, since the functions of the present 
invention are implemented by computer, the program code 
installed in the computer also Implements the present 
invention. In other words, the claims of the present 
invention also cover a computer program for the purpose 
of Implementing the functions of the present invention. 

In this case, so long as the system or apparatus 
has the functions of the program, the program may be 
executed in any form, such as an object code, a program 
executed by an interpreter, or scrip data supplied to 
an operating system. 

Example of storage media that can be used for 
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supplying the program are a floppy disk, a hard disk, 
an optical disk, a magneto -optical disk, a CD-ROM, a 
CD-R, a CD-RW, a magnetic tape, a non-volatile type 
memory card, a ROM, and a DVD (DVD-ROM and a DVD-R). 

As for the method of supplying the program, a 
client computer can be connected to a website on the 
Internet using a browser of the client computer, and 
the computer program of the present invention or an 
automatically- installable compressed file of the 
program can be downloaded to a recording medium such as 
a hard disk. Further, the program of the present 
invention can be supplied by dividing the program code 
constituting the program into a plurality of files and 
downloading the files from different websites. In 
other words, a WWW (World Wide Web) server that 
downloads, to multiple users, the program files that 
implement the functions of the present invention by 
computer is also covered by the claims of the present 
invention . 

It is also possible to encrypt and stpre the 
program of the present invention on a storage medium 
such as a CD-ROM, distribute the storage medium to 
users, allow users who meet certain requirements to 
download decryption key information from a website via 
the Internet, and allow these users to decrypt the 
encrypted program by using the key information, whereby 
the program is Installed in the user computer. 
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Besides the cases where the aforementioned 
functions according to the embodiments are implemented 
by executing the read program by computer, an operating 
system or the like running on the computer may perform 
all or a part of the actual processing so that the 
functions of the foregoing embodiments can be 
Implemented by this processing. 

Furthermore , after the program read from the 
storage medium is written to a function expansion board 
Inserted Into the computer or to a memory provided in a 
function expansion unit connected to the computer, a 
CPU or the like mounted on the function expansion board 
or function expansion unit performs all or a part of 
the actual processing so that the functions of the 
foregoing embodiments can be implemented by this 
processing. 

As many apparently widely different embodiments 
of the present invention can be made without departing 
from the spirit and scope thereof, it is to be 
understood that the invention is not limited to the 
specific embodiments thereof except as defined in the 
appended claims. 

CLAIM OF PRIORITY 

This application claims priority from Japanese 
Patent Application No. 2004-090059 filed on March 25, 
2004, the entire contents of which are hereby 
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incorporated by reference herein. 
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CLAIMS 

•1. A data processing apparatus for processing 
data for respective pages, comprising: 

a data reception unit for receiving at least data 
of a first format for respective pages; 

a data conversion unit for converting the data of 
the first format into data of a second format; 

a page data management unit for managing the data 
of the first and second formats in first and second 
page data in association with each other; and 

a control unit for monitoring a storage state of 
the data of the first format in a memory, and 
permitting a predetermined process for the data of the 
first format in accordance with the storage state. 

2. The apparatus according to claim 1, wherein 
said control unit further determines whether or not the 
data received by said data reception unit is the data 
of the second format, and wherein when the received 
data is the data of the second format, a conversion 
operation of said data conversion unit is stopped. 

3. The apparatus according to claim 1 or 2 , - 
wherein when said control unit determines that storage 
of the data of the first format in the memory is 
complete, said control unit permits said data 
conversion unit to start a data conversion operation 
from the first format to the second format. 
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4. The apparatus according to claim 3, wherein 
said control unit monitors completion of the conversion 
operation of said data conversion unit and a storage 
state of the data of the second format in the memory, 
and permits a predetermined process for the data of the 
second format in accordance with the storage state* 

5. The apparatus according to any one of claims 
1 to 4, wherein said control unit generates said page 
data management unit in response to the data reception 
by said data reception unit. 

6. The apparatus according to claim 5, wherein 
said page data management unit is generated for data of 
each page received by said data reception unit, and 
when data including a plurality of pages are received, 
said page data management unit manages the first and 
second page data while associating respective pages 
with each other. 

7. The apparatus according to any one of claims 
1 to 6, wherein said control unit monitors whether or 
not a process execution unit for executing the 
predetermined process Issues a request for processing 
the data of the first or second format, and controls 
said page data management unit to manage the 
availability of the request. 

8. The apparatus according to claim 7, wherein 
the first format is one of a plurality of data formats 
including raw data, JBIG data, JPEG data, TIFF data. 
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and TEXT data, and data of the second format has a JBIG 
data format. 

9. A data processing method for processing data 
for respective pages, comprising: 

a data reception step of receiving at least data 
of a first format for respective pages; 

a first page data generation step of generating 
first page data used to manage the data of the first 
format; 

a control step of monitoring a storage state of 
the data of the first format in the memory, and 
permitting a predetermined process for the data of the 
first format in accordance with the storage state; 

a data conversion step of converting the data of 
the first format into data of a second format; 

a second page data generation step of generating 
second page data used to manage the data of the second 
format ; and 

a page data management step of managing the data 
of the first and second formats in first and second 
page data in association with each other, 

10. The method according to claim 9, wherein 
in the control step, it is further determined 
whether or not the data received by said data reception 
unit is the data of the second format, and 



P205-0073WO 

- 27 - 

when the received data is the data of the second 
format, a conversion operation in the data conversion 
step is stopped. 

11. The method according to claim 9 or 10, 
wherein, in the control step, when it is determined 
that storage of the data of the first format in the 
memory is complete, a data conversion operation is 
permitted to start from the first format to the second 
format in the data conversion step. 

12. The method according to claim 11, further 
comprising 

a process permission step of monitoring 
completion of the conversion operation in the data 
conversion step and a storage state of the data of the 
second format in the memory, and permitting a 
predetermined process for the data of the second format 
in accordance with the storage state. 

13. The method according to any one of claims 9 
to 12, further comprising 

a request monitoring step of monitoring whether 
or not a process execution unit for executing the 
predetermined process Issues a request for processing 
the data of the first or second format, and controlling 
the first or second page data to manage the 
availability of the request. 

14. The method according to claim 13, wherein the 
first format is one of a plurality of data formats 
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Including raw data, JBIG data, JPEG data, TIFF data, 
and TEXT data, and data of the second format has a JBIG 
data format. 

15. A computer program characterized by making a 
computer execute a data processing method of any one of 
claims 9 to 14. 

16. A data processing apparatus for processing 
data for respective pages, comprising: 

a data reception unit for receiving data 
including a plurality of pages in a plurality of kinds 
of formats; 

a format determination unit for determining a 
data format for a predetermined page of the plurality 
of pages, and setting the data format as a reception 
data format; 

a data conversion unit for converting data of the 
reception data format into data of a basic format in 
the data processing apparatus; 

a page data management unit for supporting and 
generating page data in the reception data format and 
the basic format, and managing the page data in 
association with each other; and 

a control unit for monitoring a storage state of 
the data of the reception data format in the memory, 
and permitting a predetermined process for the data of 
the reception data format in accordance with the 
storage state. 
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17. The apparatus according to claim 16 , wherein 
said page data management unit is generated for each 
page with respect to the data including the plurality 
of pages, and said page data management units for the 
respective pages are associated with each other to 
manage the page data of the reception data format and 
the basic format, 

18. The apparatus according to claim 16 or 17 , 
wherein said control unit monitors completion of the 
conversion operation of said data conversion unit and a 
storage state of the data of the basic format in the 
memory, and permits a predetermined process for the 
data of the basic format in accordance with the storage 
state. 

19. The apparatus according to any one of claims 
16 to 18, wherein said control unit monitors whether or 
not a process execution unit for executing the 
predetermined process Issues a request for processing 
the data of the reception data format or the basic 
format, and controls said page data management unit to 
manage the availability of the request. 
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ABSTRACT 

This Invention efficiently implements encoding 
processes corresponding to respective image processing 
functions while minimizing the memory use size in the 
apparatus in an image processing apparatus having many 
image processing functions. A data processing 
apparatus of this invention includes a data reception 
unit for receiving at least data of a first format for 
respective pages, a data conversion unit for converting 
the data of the first format into data of a second 
format , a page data management unit for managing the 
data of the first and second formats in first and 
second page data in association with each other, and a 
control unit for monitoring a storage state of the data 
of the first format in the memory, and permitting a 
predetermined process for the data of the first format 
in accordance with the storage state. When the control 
unit determines that storage of the data of the first 
format in the memory is complete, the control unit 
permits the data conversion unit to start a data 
conversion operation from the first format to the 
second format. Also, the control unit monitors 
completion of the conversion operation of the data 
conversion unit and a storage state of the data of the 
second format in the memory, and permits a 
predetermined process for the data of the second format 
in accordance with the storage state. 



